package cn.iocoder.yudao.module.tms.controller.admin.companybaseinfo.vo;

import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;

import java.time.LocalDate;
import java.util.*;
import java.math.BigDecimal;
import com.fasterxml.jackson.annotation.JsonFormat;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import cn.idev.excel.annotation.*;

@Schema(description = "管理后台 - 公司基本信息 Response VO")
@Data
@ExcelIgnoreUnannotated
public class CompanyBaseInfoRespVO {

    @Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "25949")
    @ExcelProperty("主键")
    private Long id;

    @Schema(description = "公司简称", example = "李四")
    @ExcelProperty("公司简称")
    private String shortName;

    @Schema(description = "公司全称", requiredMode = Schema.RequiredMode.REQUIRED, example = "王五")
    @ExcelProperty("公司全称")
    private String fullName;

    @Schema(description = "公司英文名", example = "赵六")
    @ExcelProperty("公司英文名")
    private String englishName;

    @Schema(description = "公司地址")
    @ExcelProperty("公司地址")
    private String address;

    @Schema(description = "服务项目")
    @ExcelProperty("服务项目")
    private String serviceProject;

    @Schema(description = "统一社会信用代码", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("统一社会信用代码")
    private String socialCreditCode;

    @Schema(description = "公司简介")
    @ExcelProperty("公司简介")
    private String introduction;

    @Schema(description = "注册资金（万元）")
    @ExcelProperty("注册资金（万元）")
    private BigDecimal registeredCapital;

    @Schema(description = "开户日期")
    @ExcelProperty("开户日期")
    @JsonFormat(pattern = "yyyy-MM-dd")
    private LocalDate accountOpeningDate;

    @Schema(description = "开户行信息及收款账户")
    @ExcelProperty("开户行信息及收款账户")
    private String bankAccountInfo;

    @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("创建时间")
    private LocalDateTime createTime;

}